/*
 * @lc app=leetcode.cn id=377 lang=java
 *
 * [377] 组合总和 Ⅳ
 */

// @lc code=start
class Solution {
    public int combinationSum4(int[] nums, int target) {
        // 有重复的
        // 外层遍历背包，内层遍历物品
        int[] dp = new int[target + 1];

        dp[0] = 1;

        for(int i = 0; i <= target; i++) {
            for(int j = 0; j < nums.length; j++) {
                if(i >= nums[j])
                    dp[i] += dp[i-nums[j]];
            }
        }
        return dp[target];

    }
}
// @lc code=end

